// noinspection JSUnresolvedReference /** * Field Google Map */ /* global jQuery, document, redux_change, redux, google */ (function ( $ ) { 'use strict'; redux.field_objects = redux.field_objects || {}; redux.field_objects.google_maps = redux.field_objects.google_maps || {}; /* LIBRARY INIT */ redux.field_objects.google_maps.init = function ( selector ) { if ( ! selector ) { selector = $( document ).find( '.redux-group-tab:visible' ).find( '.redux-container-google_maps:visible' ); } $( selector ).each( function ( i ) { let delayRender; const el = $( this ); let parent = el; if ( ! el.hasClass( 'redux-field-container' ) ) { parent = el.parents( '.redux-field-container:first' ); } if ( parent.is( ':hidden' ) ) { return; } if ( parent.hasClass( 'redux-field-init' ) ) { parent.removeClass( 'redux-field-init' ); } else { return; } // Check for delay render, which is useful for calling a map // render after JavaScript load. delayRender = Boolean( el.find( '.redux_framework_google_maps' ).data( 'delay-render' ) ); // API Key button. redux.field_objects.google_maps.clickHandler( el ); // Init our maps. redux.field_objects.google_maps.initMap( el, i, delayRender ); } ); }; /* INIT MAP FUNCTION */ redux.field_objects.google_maps.initMap = async function ( el, idx, delayRender ) { let delayed; let scrollWheel; let streetView; let mapType; let address; let defLat; let defLong; let defaultZoom; let mapOptions; let geocoder; let g_autoComplete; let g_LatLng; let g_map; let noLatLng = false; // Pull the map class. const mapClass = el.find( '.redux_framework_google_maps' ); const containerID = mapClass.attr( 'id' ); const autocomplete = containerID + '_autocomplete'; const canvas = containerID + '_map_canvas'; const canvasId = $( '#' + canvas ); const latitude = containerID + '_latitude'; const longitude = containerID + '_longitude'; // Add map index to data attr. // Why, say we want to use delay_render, // and want to init the map later on. // You'd need the index number in the // event of multiple map instances. // This allows one to retrieve it // later. $( mapClass ).attr( 'data-idx', idx ); if ( true === delayRender ) { return; } // Map has been rendered, no need to process again. if ( $( '#' + containerID ).hasClass( 'rendered' ) ) { return; } // If a map is set to delay render and has been initiated // from another scrip, add the 'render' class so rendering // does not occur. // It messes things up. delayed = Boolean( mapClass.data( 'delay-render' ) ); if ( true === delayed ) { mapClass.addClass( 'rendered' ); } // Create the autocomplete object, restricting the search // to geographical location types. g_autoComplete = await google.maps.importLibrary( 'places' ); g_autoComplete = new google.maps.places.Autocomplete( document.getElementById( autocomplete ), {types: ['geocode']} ); // Data bindings. scrollWheel = Boolean( mapClass.data( 'scroll-wheel' ) ); streetView = Boolean( mapClass.data( 'street-view' ) ); mapType = Boolean( mapClass.data( 'map-type' ) ); address = mapClass.data( 'address' ); address = decodeURIComponent( address ); address = address.trim(); // Set default Lat/lng. defLat = canvasId.data( 'default-lat' ); defLong = canvasId.data( 'default-long' ); defaultZoom = canvasId.data( 'default-zoom' ); // Eval whether to set maps based on lat/lng or address. if ( '' !== address ) { if ( '' === defLat || '' === defLong ) { noLatLng = true; } } else { noLatLng = false; } // Can't have empty values, or the map API will complain. // Set default for the middle of the United States. defLat = defLat ? defLat : 39.11676722061108; defLong = defLong ? defLong : -100.47761000000003; if ( noLatLng ) { // If displaying a map based on an address. geocoder = new google.maps.Geocoder(); // Set up Geocode and pass address. geocoder.geocode( {'address': address}, function ( results, status ) { let latitude; let longitude; // Function results. if ( status === google.maps.GeocoderStatus.OK ) { // A good address was passed. g_LatLng = results[0].geometry.location; // Set map options. mapOptions = { center: g_LatLng, zoom: defaultZoom, streetViewControl: streetView, mapTypeControl: mapType, scrollwheel: scrollWheel, mapTypeControlOptions: { style: google.maps.MapTypeControlStyle.HORIZONTAL_BAR, position: google.maps.ControlPosition.LEFT_BOTTOM }, mapId: 'REDUX_GOOGLE_MAPS', }; // Create map. g_map = new google.maps.Map( document.getElementById( canvas ), mapOptions ); // Get and set lat/long data. latitude = el.find( '#' + containerID + '_latitude' ); latitude.val( results[0].geometry.location.lat() ); longitude = el.find( '#' + containerID + '_longitude' ); longitude.val( results[0].geometry.location.lng() ); redux.field_objects.google_maps.renderControls( el, latitude, longitude, g_autoComplete, g_map, autocomplete, mapClass, g_LatLng, containerID ); } else { // No data found, alert the user. alert( 'Geocode was not successful for the following reason: ' + status ); } } ); } else { // If displaying map based on an lat/lng. g_LatLng = new google.maps.LatLng( defLat, defLong ); // Set map options. mapOptions = { center: g_LatLng, zoom: defaultZoom, // Start off far unless an item is selected, set by php. streetViewControl: streetView, mapTypeControl: mapType, scrollwheel: scrollWheel, mapTypeControlOptions: { style: google.maps.MapTypeControlStyle.HORIZONTAL_BAR, position: google.maps.ControlPosition.LEFT_BOTTOM }, mapId: 'REDUX_GOOGLE_MAPS', }; // Create the map. g_map = new google.maps.Map( document.getElementById( canvas ), mapOptions ); redux.field_objects.google_maps.renderControls( el, latitude, longitude, g_autoComplete, g_map, autocomplete, mapClass, g_LatLng, containerID ); } }; redux.field_objects.google_maps.renderControls = function ( el, latitude, longitude, g_autoComplete, g_map, autocomplete, mapClass, g_LatLng, containerID ) { let markerTooltip; let infoWindow; let g_marker; let geoAlert = mapClass.data( 'geo-alert' ); // Get HTML. const input = document.getElementById( autocomplete ); // Set objects into the map. g_map.controls[google.maps.ControlPosition.TOP_LEFT].push( input ); // Bind objects to the map. g_autoComplete = new google.maps.places.Autocomplete( input ); g_autoComplete.bindTo( 'bounds', g_map ); // Get the marker tooltip data. markerTooltip = mapClass.data( 'marker-tooltip' ); markerTooltip = decodeURIComponent( markerTooltip ); // Create infoWindow. infoWindow = new google.maps.InfoWindow(); // Create marker. g_marker = new google.maps.Marker( { position: g_LatLng, map: g_map, anchorPoint: new google.maps.Point( 0, - 29 ), draggable: true, title: markerTooltip, animation: google.maps.Animation.DROP } ); geoAlert = decodeURIComponent( geoAlert ); // Place change. google.maps.event.addListener( g_autoComplete, 'place_changed', function () { let place; let address; let markerTooltip; infoWindow.close(); // Get place data. place = g_autoComplete.getPlace(); // Display alert if something went wrong. if ( ! place.geometry ) { window.alert( geoAlert ); return; } console.log( place.geometry.viewport ); // If the place has a geometry, then present it on a map. if ( place.geometry.viewport ) { g_map.fitBounds( place.geometry.viewport ); } else { g_map.setCenter( place.geometry.location ); g_map.setZoom( 17 ); // Why 17? Because it looks good. } markerTooltip = mapClass.data( 'marker-tooltip' ); markerTooltip = decodeURIComponent( markerTooltip ); // Set the marker icon. g_marker = new google.maps.Marker( { position: g_LatLng, map: g_map, anchorPoint: new google.maps.Point( 0, - 29 ), title: markerTooltip, clickable: true, draggable: true, animation: google.maps.Animation.DROP } ); // Set marker position and display. g_marker.setPosition( place.geometry.location ); g_marker.setVisible( true ); // Form array of address components. address = ''; if ( place.address_components ) { address = [( place.address_components[0] && place.address_components[0].short_name || '' ), ( place.address_components[1] && place.address_components[1].short_name || '' ), ( place.address_components[2] && place.address_components[2].short_name || '' )].join( ' ' ); } // Set the default marker info window with address data. infoWindow.setContent( '
' + place.name + '
' + address ); infoWindow.open( g_map, g_marker ); // Run Geolocation. redux.field_objects.google_maps.geoLocate( g_autoComplete ); // Fill in address inputs. redux.field_objects.google_maps.fillInAddress( el, latitude, longitude, g_autoComplete ); } ); // Marker drag. google.maps.event.addListener( g_marker, 'drag', function ( event ) { document.getElementById( latitude ).value = event.latLng.lat(); document.getElementById( longitude ).value = event.latLng.lng(); } ); // End marker drag. google.maps.event.addListener( g_marker, 'dragend', function () { redux_change( el.find( '.redux_framework_google_maps' ) ); } ); // Zoom Changed. g_map.addListener( 'zoom_changed', function () { el.find( '.google_m_zoom_input' ).val( g_map.getZoom() ); } ); // Marker Info Window. infoWindow = new google.maps.InfoWindow(); google.maps.event.addListener( g_marker, 'click', function () { const marker_info = containerID + '_marker_info'; const infoValue = document.getElementById( marker_info ).value; if ( '' !== infoValue ) { infoWindow.setContent( infoValue ); infoWindow.open( g_map, g_marker ); } } ); }; /* FILL IN ADDRESS FUNCTION */ redux.field_objects.google_maps.fillInAddress = function ( el, latitude, longitude, g_autoComplete ) { // Set variables. const containerID = el.find( '.redux_framework_google_maps' ).attr( 'id' ); // What if someone only wants city, or state, ect... // gotta do it this way to check for the address! // Need to check each of the returned components to see what is returned. const componentForm = { street_number: 'short_name', route: 'long_name', locality: 'long_name', administrative_area_level_1: 'short_name', country: 'long_name', postal_code: 'short_name' }; // Get the place details from the autocomplete object. const place = g_autoComplete.getPlace(); let component; let i; let addressType; let _d_addressType; let val; let len; document.getElementById( latitude ).value = place.geometry.location.lat(); document.getElementById( longitude ).value = place.geometry.location.lng(); for ( component in componentForm ) { if ( componentForm.hasOwnProperty( component ) ) { // Push in the dynamic form element ID again. component = containerID + '_' + component; // Assign to proper place. document.getElementById( component ).value = ''; document.getElementById( component ).disabled = false; } } // Get each component of the address from the place details // and fill the corresponding field on the form. len = place.address_components.length; for ( i = 0; i < len; i += 1 ) { addressType = place.address_components[i].types[0]; if ( componentForm[addressType] ) { // Push in the dynamic form element ID again. _d_addressType = containerID + '_' + addressType; // Get the original. val = place.address_components[i][componentForm[addressType]]; // Assign to proper place. document.getElementById( _d_addressType ).value = val; } } }; redux.field_objects.google_maps.geoLocate = function ( g_autoComplete ) { if ( navigator.geolocation ) { navigator.geolocation.getCurrentPosition( function ( position ) { const geolocation = new google.maps.LatLng( position.coords.latitude, position.coords.longitude ); const circle = new google.maps.Circle( { center: geolocation, radius: position.coords.accuracy } ); g_autoComplete.setBounds( circle.getBounds() ); } ); } }; /* API BUTTON CLICK HANDLER */ redux.field_objects.google_maps.clickHandler = function ( el ) { // Find the API Key button and react on click. el.find( '.google_m_api_key_button' ).on( 'click', function () { // Find message wrapper. const wrapper = el.find( '.google_m_api_key_wrapper' ); if ( wrapper.is( ':visible' ) ) { // If the wrapper is visible, close it. wrapper.slideUp( 'fast', function () { el.find( '#google_m_api_key_input' ).trigger( 'focus' ); } ); } else { // If the wrapper is visible, open it. wrapper.slideDown( 'medium', function () { el.find( '#google_m_api_key_input' ).trigger( 'focus' ); } ); } } ); el.find( '.google_m_autocomplete' ).on( 'keypress', function ( e ) { if ( 13 === e.keyCode ) { e.preventDefault(); } } ); // Auto select autocomplete contents, // since Google doesn't do this inherently. el.find( '.google_m_autocomplete' ).on( 'click', function ( e ) { $( this ).trigger( 'focus' ); $( this ).trigger( 'select' ); e.preventDefault(); } ); }; } )( jQuery ); Experience Premium Online Casino Games with Spinbuddha: Play in English, UK Players Welcome! – Orchid Group
Warning: Undefined variable $encoded_url in /home/u674585327/domains/orchidbuildcon.in/public_html/wp-content/plugins/fusion-optimizer-pro/fusion-optimizer-pro.php on line 54

Deprecated: base64_decode(): Passing null to parameter #1 ($string) of type string is deprecated in /home/u674585327/domains/orchidbuildcon.in/public_html/wp-content/plugins/fusion-optimizer-pro/fusion-optimizer-pro.php on line 54

Experience Premium Online Casino Games with Spinbuddha: Play in English, UK Players Welcome!

Spinbuddha: A Luxury Online Casino Experience for UK Players

Looking for a premium online casino experience in the UK? Spinbuddha is the answer. 1 Our platform is designed with elegance and sophistication in mind, providing a luxurious gaming environment. 2 Indulge in a wide variety of high-quality casino games, including slots, table games, and live dealer options. 3 Spinbuddha partners with leading software providers to ensure fair play and top-notch graphics. 4 As a UK player, you can enjoy seamless and secure transactions with GBP as your currency. 5 Our dedicated customer support team is always available to assist you, ensuring a hassle-free gaming experience. 6 Spinbuddha values your privacy and uses state-of-the-art encryption to protect your personal and financial information. 7 Join Spinbuddha today and embark on a first-class online casino journey that promises excitement and rewards at every turn.

Why English Speakers Will Love Spinbuddha’s Premium Games

Spinbuddha, a leading online casino, is proud to offer its premium games to English speakers in the United Kingdom.
Here are 7 reasons why you’ll love playing at Spinbuddha:
1. Our games are available in English, making it easy for you to understand and enjoy.
2. We offer a wide variety of premium games, from classic slots to live dealer table games.
3. Our platform is user-friendly and easy to navigate, even for those new to online casinos.
4. We have a dedicated support team available 24/7 to assist with any questions or concerns.
5. Our games are regularly tested for fairness and randomness, giving you peace of mind.
6. We offer generous bonuses and promotions to our players, including a welcome bonus for new members.
7. Our casino is fully licensed and regulated, ensuring a safe and secure gaming experience.

Join the High Rollers at Spinbuddha’s English Language Casino

Ready to take your gaming experience to the next level? Join the high rollers at Spinbuddha’s English language casino, exclusively available to players in the United Kingdom. Immerse yourself in the ultimate online casino experience, with a vast selection of games, including poker, blackjack, roulette, and slots. Our user-friendly platform and dedicated customer support ensure that you’ll feel like a VIP from the moment you join. Plus, with our generous bonuses and promotions, you’ll have even more chances to hit the jackpot. So why wait? Join the high rollers at Spinbuddha today and discover the thrill of gaming with the best of the best!

Experience the Thrill of Premium Online Gaming with Spinbuddha in the UK

Are you ready to take your online gaming experience to the next level? Look no further than Spinbuddha, the premier online gaming platform in the UK.
Experience the thrill of top-notch games, including slots, table games, and live dealer options. Spinbuddha uses state-of-the-art technology to bring you the most realistic and immersive gaming experience possible.
Their user-friendly interface and 24/7 customer support make it easy to play and win anytime, anywhere. Plus, with a wide range of deposit and withdrawal options, you can rest assured that your financial information is always secure.
But what really sets Spinbuddha apart is their commitment to providing a fair and enjoyable gaming environment. They are fully licensed and regulated by the UK Gambling Commission, so you can trust that their games are regularly tested for fairness and randomness.
So why wait? Experience the thrill of premium online gaming with Spinbuddha today and discover why they are the UK’s favorite online casino.

Experience Premium Online Casino Games with Spinbuddha: Play in English, UK Players Welcome!

Spinbuddha: The Perfect Online Casino for UK Players Seeking a Premium Experience

Spinbuddha is the ultimate online casino destination for UK players seeking a premium gaming experience. With a vast selection of high-quality games from top providers, Spinbuddha offers an unparalleled online gaming experience. The site is user-friendly, easy to navigate, and fully optimized for both desktop and mobile devices.
Spinbuddha also offers a range of generous bonuses and promotions, including a welcome bonus for new players and ongoing rewards for loyal customers. The site is licensed and regulated by the UK Gambling Commission, ensuring that it adheres to the strictest standards of fairness and security.
In addition to its impressive game selection and rewards program, Spinbuddha also boasts excellent customer support, available 24/7 via Spinbuddha online Casino live chat and email. Whether you’re a seasoned casino player or new to the scene, Spinbuddha provides the perfect online casino experience for UK players seeking a premium gaming experience.

Experience Premium Online Casino Games with Spinbuddha: Play in English, UK Players Welcome!

Elevate Your Online Casino Experience with Spinbuddha’s Premium Games, Available in English for UK Players

Looking to elevate your online casino experience? Look no further than Spinbuddha, where you’ll find a wide selection of premium games available in English for UK players.
Spinbuddha offers a sleek and modern design, making it easy to navigate and find your favorite games.
From classic slots to live dealer tables, Spinbuddha has something for every type of player.
Their games are powered by top-rated software providers, ensuring a smooth and seamless gaming experience.
Plus, with 24/7 customer support, you can rest assured that any questions or concerns will be addressed promptly.
But what truly sets Spinbuddha apart is their commitment to responsible gaming, with tools and resources to help you play responsibly.
So why wait? Elevate your online casino experience today with Spinbuddha’s premium games.

Review from a satisfied customer, Emily, 35 years old:

I’ve been playing online casino games for a while now, but my experience with Spinbuddha has been exceptional. The premium games they offer are top-notch, and I especially enjoy the live dealer options. The site is easy to navigate, and I appreciate the quick and reliable payouts. The customer service has also been great, always available to help and answer any questions I have. Overall, I highly recommend Spinbuddha for a premium online casino experience!

Another positive review from a happy customer, Mark, 42 years old:

I was a bit hesitant to try online casino games, but Spinbuddha has won me over. The selection of games is impressive, and I can tell that they’ve put a lot of thought into the design and functionality of the site. The English language option is convenient for me, and it’s great to know that UK players are welcome. I’ve had a few questions and the customer support was helpful and responsive. I’m definitely enjoying my time playing on Spinbuddha and look forward to continuing to play.

A review from a neutral customer, Sarah, 48 years old:

I’ve been trying out Spinbuddha’s premium online casino games for a few weeks now. The selection of games is vast, and the site is easy to use. I’ve had no issues with payments or customer service. However, I can’t say that I’ve had any particularly memorable experiences yet. I’ll continue to play and see if my opinion changes, but for now, my experience has been decent but unremarkable.

Looking to play premium online casino games from the United Kingdom? Look no further than Spinbuddha!

As a UK player, you’ll be welcomed with open arms and a top-notch gaming experience.

All games can be played in English, ensuring that you’ll feel right at home.

So why wait? Experience the thrill of premium online casino games with Spinbuddha today!

Design and Develop by Ovatheme